Room Persistence Library দিয়ে ডেটা ম্যানেজমেন্ট

Mobile App Development - অ্যান্ড্রয়েড ডেভেলপমেন্ট (Android) - Android অ্যাপ্লিকেশন এ ডেটা স্টোরেজ
242

Room Persistence Library দিয়ে ডেটা ম্যানেজমেন্ট

Room Persistence Library হল Android এ একটি ORM (Object-Relational Mapping) লাইব্রেরি, যা SQLite ডেটাবেসের উপর ভিত্তি করে কাজ করে। এটি ডেটাবেস ম্যানেজমেন্টকে সহজ করে এবং কমপ্লেক্স SQL কোয়েরি লেখার প্রয়োজন কমায়। Room এর মাধ্যমে আপনি SQLite ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন একটি অবজেক্ট-ওরিয়েন্টেড অ্যাপ্রোচে এবং সহজেই ডেটাবেস অপারেশন যেমন ইনসার্ট, আপডেট, ডিলিট এবং রিট্রিভ করতে পারেন।

নিচে Room Library এর সাথে কাজ করার ধাপসমূহ এবং একটি পূর্ণ উদাহরণ দেওয়া হলো।


Room Persistence Library এর প্রধান উপাদান:

১. Entity: এটি একটি ক্লাস, যা ডেটাবেস টেবিলের একটি সারির প্রতিনিধিত্ব করে। প্রতিটি Entity একটি টেবিল এবং প্রতিটি ফিল্ড একটি কলাম হিসেবে কাজ করে।

২. DAO (Data Access Object): এটি একটি ইন্টারফেস, যা ডেটাবেস অপারেশন (CRUD অপারেশন) সংজ্ঞায়িত করে। DAO-এর মাধ্যমে আপনি ডেটাবেসে ইনসার্ট, আপডেট, ডিলিট, এবং কোয়েরি চালাতে পারেন।

৩. Database: এটি একটি অ্যাবস্ট্রাক্ট ক্লাস, যা RoomDatabase কে এক্সটেন্ড করে। এটি DAO গুলোর একটি তালিকা ধারণ করে এবং ডেটাবেসকে অ্যাক্সেস দেয়।


ধাপ ১: গ্রেডেল ফাইল সেটআপ করা

প্রথমে আপনার build.gradle (Module: app) ফাইলে Room লাইব্রেরির ডিপেন্ডেন্সি যোগ করতে হবে:

dependencies {
    def room_version = "2.5.2"
    implementation "androidx.room:room-runtime:$room_version"
    annotationProcessor "androidx.room:room-compiler:$room_version"
    // For Kotlin, use kapt instead of annotationProcessor
    kapt "androidx.room:room-compiler:$room_version"
}

ধাপ ২: Entity তৈরি করা

Entity একটি ক্লাস যা ডেটাবেস টেবিলকে প্রতিনিধিত্ব করে। নিচে User নামে একটি Entity এর উদাহরণ দেওয়া হলো:

import androidx.room.Entity;
import androidx.room.PrimaryKey;

@Entity(tableName = "users")
public class User {
    @PrimaryKey(autoGenerate = true)
    private int id;
    private String name;
    private String email;

    // Constructors, getters, and setters
    public User(String name, String email) {
        this.name = name;
        this.email = email;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

ধাপ ৩: DAO (Data Access Object) তৈরি করা

DAO ইন্টারফেস ডেটাবেস অপারেশনগুলো সংজ্ঞায়িত করে। নিচে একটি UserDao ইন্টারফেসের উদাহরণ দেওয়া হলো:

import androidx.room.Dao;
import androidx.room.Delete;
import androidx.room.Insert;
import androidx.room.Query;
import androidx.room.Update;

import java.util.List;

@Dao
public interface UserDao {

    @Insert
    void insert(User user);

    @Update
    void update(User user);

    @Delete
    void delete(User user);

    @Query("SELECT * FROM users")
    List<User> getAllUsers();

    @Query("SELECT * FROM users WHERE id = :userId")
    User getUserById(int userId);
}

ধাপ ৪: Database তৈরি করা

Room ডেটাবেস তৈরি করতে একটি অ্যাবস্ট্রাক্ট ক্লাস তৈরি করতে হবে, যা RoomDatabase কে এক্সটেন্ড করবে:

import androidx.room.Database;
import androidx.room.RoomDatabase;

@Database(entities = {User.class}, version = 1)
public abstract class AppDatabase extends RoomDatabase {
    public abstract UserDao userDao();
}

ধাপ ৫: ডেটাবেস ইন্সট্যান্স তৈরি করা

Activity বা Application ক্লাসে ডেটাবেস ইন্সট্যান্স তৈরি করতে হবে:

import androidx.appcompat.app.AppCompatActivity;
import androidx.room.Room;
import android.os.Bundle;

public class MainActivity extends AppCompatActivity {
    private AppDatabase db;
    private UserDao userDao;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // ডেটাবেস ইন্সট্যান্স তৈরি
        db = Room.databaseBuilder(getApplicationContext(),
                AppDatabase.class, "my-database").allowMainThreadQueries().build();

        userDao = db.userDao();

        // ডেটা ইনসার্ট করা
        User newUser = new User("John Doe", "john.doe@example.com");
        userDao.insert(newUser);

        // সমস্ত ব্যবহারকারীর তালিকা প্রাপ্তি
        List<User> users = userDao.getAllUsers();
        for (User user : users) {
            System.out.println("User ID: " + user.getId() + ", Name: " + user.getName());
        }
    }
}

নোট: সাধারণত, ডেটাবেস অপারেশনগুলো ব্যাকগ্রাউন্ড থ্রেডে সম্পন্ন করা উচিত। উপরের উদাহরণে allowMainThreadQueries() ব্যবহার করা হয়েছে, যা প্রোডাকশন অ্যাপ্লিকেশনে ব্যবহার করা উচিত নয়। AsyncTask, Executor, বা Coroutine (Kotlin) ব্যবহার করে ডেটাবেস অপারেশন ব্যাকগ্রাউন্ডে করা উচিত।


Room এর সুবিধা এবং সীমাবদ্ধতা

সুবিধাসীমাবদ্ধতা
Type Safety: কম্পাইল টাইমে কোয়েরি চেক করা হয়জটিল কোয়েরি এবং কাস্টমাইজেশনের ক্ষেত্রে কিছুটা সীমাবদ্ধ
Annotations: কোড সহজ এবং পরিষ্কার রাখেবড় ডেটা সেটের জন্য পারফরম্যান্স অপ্টিমাইজ করা প্রয়োজন
Lifecycle-Aware: LiveData এবং ViewModel এর সাথে সহজে ইন্টিগ্রেটেডপ্রাথমিক সেটআপ কিছুটা জটিল হতে পারে
Offline Support: ডেটা অফলাইন সংরক্ষণ করেবড় ডেটাবেস ম্যানেজমেন্টের জন্য বিকল্প হিসেবে Room সীমিত

উপসংহার

Room Persistence Library ব্যবহার করে আপনি Android অ্যাপ্লিকেশনে একটি শক্তিশালী এবং সহজ ডেটাবেস ম্যানেজমেন্ট সিস্টেম তৈরি করতে পারেন। এটি SQLite এর উপর ভিত্তি করে কাজ করে এবং ডেটা ম্যানিপুলেশন এবং স্টোরেজকে সহজ করে। Room এর সঠিক ব্যবহার একটি অ্যাপ্লিকেশনকে দ্রুত এবং কার্যকরী ডেটা ম্যানেজমেন্ট সিস্টেমে রূপান্তর করতে পারে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...